"Рабочая" версия SampleSmartConsole не получает инструмент и портфель

"Рабочая" версия SampleSmartConsole не получает инструмент и портфель


Приветствую, недавно закончил курс "Базовый" по S#, пытаюсь довести до ума пример SampleSmartConsole, но выполнение програмы останавливается после сообщения "Дожидаемся появления в программе инструмента RIH и портфеля "
Хотелось бы узнать где ошибка в этом коде и по какому алгоритму самому определять подобные моменты.


Code
using System;
using System.Net;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using StockSharp.Algo;
using StockSharp.BusinessEntities;
using StockSharp.Smart;
using System.Threading;
using Ecng.Collections;
using Ecng.Common;
using StockSharp.Algo.Candles;


namespace MyFirstBot
{

    class Program
    {

        static string login = "Мой логин";
        static string password = "QKVDBU";
        public static Portfolio portfolio;
        public static Security secObject;
        static string sec;
        private StockSharp.Algo.Candles.CandleManager _candleManager;
        private TimeSpan _candleWidth;
        private SmartTrader trader;
        const string secCode = "RIH2";
        const string account = "Мой счет";


        static string ipAddress = "62.141.86.229";
        static System.Net.IPAddress addr = System.Net.IPAddress.Parse(ipAddress);
        static System.Net.IPEndPoint server = new System.Net.IPEndPoint(addr, 8090);

        static void Main()
        {


            try
            {
                var trader = new SmartTrader(login, password, server);
                var waitHandle = new AutoResetEvent(false);
                trader.Connected += () =>
                {
                    Console.WriteLine("Подключение было произведено успешно.");

                   waitHandle.Set();
                };
                Console.WriteLine("Производим подключение...");

                trader.Connect();
   
                waitHandle.WaitOne();


                trader.NewPortfolios += portfolios =>
                {
                    // необходимое условие работы в SmartCOM
                    portfolios.ForEach(trader.RegisterPortfolio);

                    if (portfolio == null)
                    {
                       
                        portfolio = portfolios.FirstOrDefault(p => p.Name == account);

                        if (portfolio != null)
                        {
                            Console.WriteLine("Портфель {0} появился.", account);

                            if (secObject != null)
                                waitHandle.Set();
                        }
                    }
                };

               
                trader.NewSecurities += securities =>
                        {
                            if (secObject == null)
                            {
                                
                                secObject = securities.FirstOrDefault(sec => sec.Code == secCode && sec.Type == SecurityTypes.Equity);

                                if (secObject != null)
                                {
                                    Console.WriteLine("Инструмент RIH2 появился.");

                                    if (portfolio != null)
                                        waitHandle.Set();
                                }
                            }
                        };
                Console.WriteLine("Дожидаемся появления в программе инструмента RIH и портфеля {0}...".Put(account));

                // запускаем экспорт по инструментам и портфелям
                trader.StartExport();

                // дожидаемся появления портфеля и инструмента
                waitHandle.WaitOne();

                trader.SecuritiesChanged += securities =>
                {
                    // если инструмент хоть раз изменился (по нему пришли актуальные данные)
                    if (securities.Contains(secObject))
                        waitHandle.Set();
                };

                Console.WriteLine("Дожидаемся обновления данных по инструменту RIH2...");


                trader.RegisterSecurity(secObject);
                waitHandle.WaitOne();




          }
            catch (Exception ex)
            {
                Console.WriteLine(ex);
                
            }
            Console.ReadKey();
        }
    
    }
}

Tags:


Thanks:


1 2  >
Mikhail Sukhov

Avatar
Date: 12/15/2011
Reply


Что-нибудь еще печатает?
Thanks:

Андрей Александрович

Avatar
Date: 12/15/2011
Reply


Нет больше ничего не происходит. Если вбить данные реального счета и IP боевого сервера то остановка происходит на этой же стадии.
Если заменить в коде waitHandle.WaitOne на скажем Thread.Sleep(5000) чтобы выполнение программы дошло до вывода исключений то в командной строке появляется определенный текст но я не знаю как скопировать его на форум.
Thanks:

Mikhail Sukhov

Avatar
Date: 12/15/2011
Reply


Можете перед

portfolio = portfolios.FirstOrDefault(p => p.Name == account);

вывести на экран все portfolios, которые пришли. По инструменту. А справочник инструментов в СмартТрейде обновлен?
Thanks:

Андрей Александрович

Avatar
Date: 12/16/2011
Reply


Пробовал ставить вывод на экран в разные места кода... Списки обновлены, СмартТрейд подключается к демо серверу без проблем.
При размещении
Code
Console.WriteLine("Инструменты или портфели");  
Console.ReadKey();

в разные места в коде не дает никаких результатов. Причем размещение в тела функций событий появления новых инструментов и новых портфелей этих двух строчек не прерывает программу для нажатия клавиши, следовательно в моем понимании эти события вообще не дергаются...
Михаил, если у вас есть минутка свободного времени, вы не могли бы скопировать этот код к себе в Visual Studio и проверить его работоспособность?
На курсах робота писали под Quik там всё выгружалось нормально а теперь выходит сам я не могу даже к системе подключится толком...
Thanks:

Mikhail Sukhov

Avatar
Date: 12/16/2011
Reply


Просьба актуальна из сообщения http://stocksharp.com/posts/m/14674/
Thanks:

Андрей Александрович

Avatar
Date: 12/16/2011
Reply


Михаил, если у вас работает приведенный выше код, то по какой причине могут не приходить новые инструменты и портфели на моем компьютере? Какая у вас версия SmartCom? Какие еще варианты решения этой проблемы можно попробовать?
Судя по количеству просмотров этой темы с подобными трудностями столкнулся не только я...
Хотелось бы быстрее устранить неполадки, возникшие по неведомым мне причинам, и приступить к написанию алгоритма.
Буду благодарен за помощь...
Thanks:

Mikhail Sukhov

Avatar
Date: 12/16/2011
Reply


Прочите пожалуйста еще раз мое сообщение http://stocksharp.com/posts/m/14674/
Thanks:

Андрей Александрович

Avatar
Date: 12/16/2011
Reply


Я внимательно читаю все ваши сообщения

Eridu
Пробовал ставить вывод на экран
При размещении
Code
Console.WriteLine("portfolios");  

не дает никаких результатов. Cледовательно в моем понимании эти события вообще не дергаются...


trader.ProcessDataError ничего не выводит.
Пример SampleSmart подключается к демо серверу, но списки инструментов и портфелей пусты.
Thanks:

Андрей Александрович

Avatar
Date: 12/16/2011
Reply


Сейчас протестировал соединение через Smart COM Test Connect. Все портфели и котировки идут в штатном режиме.
Выходит что-то не так в коде...
Thanks:

Mikhail Sukhov

Avatar
Date: 12/16/2011
Reply


Eridu
Сейчас протестировал соединение через Smart COM Test Connect. Все портфели и котировки идут в штатном режиме.
Выходит что-то не так в коде...


Вы можете ответить еще на этот вопрос http://stocksharp.com/posts/m/14650/ ? Как минимум должно печататься "Производим подключение..."
Thanks:
1 2  >

Attach files by dragging & dropping, , or pasting from the clipboard.

loading
clippy